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FORMATTING CONTENT BY EXAMPLE 
COPYRIGHT NOTICE 

A portion of the disclosure of this patent document contains material that is 
subject to copyright protection. The copyright owner has no objection to the facsimile 
reproduction by anyone of the patent document or the patent disclosure, as it appears in 
the Patent and Trademark Office patent file or records, but otherwise reserves all 
copyright rights. 

BACKGROUND OF THE INVENTION 

The invention relates to apparatus and process for generating content. 
The Internet is becoming an increasingly popular medium for communicating and 
publishing widely accessible documents. A network of networks, the Internet transfers 
information using a common protocol that tells computers connected to the network how 
to locate and exchange files with one another. Documents communicated over the 
Internet generally conform to a Hyper Text Markup Language (HTML) that a World- 
Wide- Web (WWW or Web) browser can translate and display. Once posted on a Web 
server, these documents or compilations of pages can be retrieved and viewed by anyone 
who has access to the Internet. 

Each document is essentially a collection of HTML codes or tags which provide 
the document with a general structure of a head and a body, as well as headings, format 
controls, forms, tables, and one or more element types. A basic familiarity with HTML 
codes is only one aspect in the process of creating HTML documents. Another issue 
relates to the process of editing such documents. Although a conventional text editor or 
word processor can be used to add HTML markups to the document, such method of 
composing and editing the HTML document is quite tedious as the process does not allow 
a designer to see the document as actually displayed by the browser. Without visual 
feedback, the process of composing and editing the HTML document can be error-prone 
and inefficient. Moreover, when the HTML document contains elements other than the 
usual text and text formatting codes, the process of composing and editing the HTML 
document can be challenging. For example, if the image elements were embedded in the 
document, the conventional text editor or word processor would reference each image 
using only its access path and file name. Consequently, the designer has to be more 
careful and more exact hi selecting the elements, as the designer cannot visually verify 
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that the correct image is being edited* Hence, the difficulty in generating the desired 
HTML document is increased when non-text elements are embedded in the document. 

The difficulty is particularly accentuated for the development of web sites in 
which the content or interaction of the web site changes based on designer or 
environmental information. Examples of such sites include on-line catalogs, news sites, 
or e-commerce sites. 

Typically, to support dynamic web sites, a web server called a dynamic content 
server processes pages to insert or replace content at run-time. Examples include 
Microsoft's Internet Information Server (IIS), which processes Active Server Pages 
(ASP). 

Currently, web sites are generally authored in two steps: 

(1 ) A designer creates the look and feel of the web site by creating a mock-up 
of the site in Photoshop. 

(2) The Photoshop image is then handed to programmers who hand-code the 
web pages in HTML and script code to be executed by a content server. 

This two-step process is caused by the fact that WYSIWYG HTML editors are 
insufficiently expressive to show what the designer wants, and; that existing content 
specification systems generally imbed processing instructions directly within the HTML, 
making it hard for them to co-exist with WYSIWYG HTML editors. An example of 
these processing instructions is exemplified by the following Active Server Page (ASP) 
code 

<BODY> 
<% 

set patents = CrcateObject( fit ADODB.RecordSet") 

patents.Open "myPatentDatabase" 

%> 

<TABLE> 
<TR> 

<TH>Title</TH> 
<TH>Description</TH> 
</TR> 

<% while not patents EOF %> 
<TR> 

<TD><%^atents('TATE^ 
<TD><^/o^atents("SH^ 
</TR> 

<% patents-MoveNext %> 
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This two-step process is inefficient since the page is in effect designed twice: once 
in Photoshop, and once in HTML file. Moreover, the designer cannot go back and make 
changes to the HTML file, because the ASP code cannot be easily read back into a 
WYSIWYG editor since ASP is a language-independent framework designed by 
Microsoft for efficient coding of server-side scripts that are executed by a Web server in 
response to a user's request for a URL. ASP scripts are similar to other server-side 
scripting such as Perl and Python. Not surprisingly, although many people can design 
web pages, only a few designers can compose web sites with ease. 

SUMMARY OF THE INVENTION 

The system and techniques specify content insertions based on elements, each 
with a representative content The format, style, and layout of the representative content 
of the elements is used to format, style, and layout the content. 

A method generates a document by: inserting one or more placeholders in the 
document; binding each placeholder to a content source; and compiling the placeholders 
into code to generate content for the document based on the content source. The method 
then executes the code to generate the content and presenting the content of the document 
if in a presentation mode or restores the placeholder if in an edit mode. 

Implementations of the invention may include one or more of the following. The 
placeholders can be formatted and annotated. Executable code can then be generated 
from the annotations to retrieve the content. The document can then be rendered based on 
the content The generating of executable codes can include generating code to obtain 
content from a database. The code can be embedded as attributes in the placeholder. The 
placeholder can be a mark-up element, and can be an HTML element or an XML 
element. The method can include specifying a content insertion based on the placeholder, 
each placeholder having a representative content. The method can also use the 
formatting,, styling, or layout of the representative content of the placeholder to format, 
style, or layout the content. 

In another aspect, a method generates a document by inserting one or more 
placeholders in the document; binding each placeholder to a content source; and 
interpreting the placeholders and presenting the content of the document if in a 
presentation mode or restoring the placeholder if in an edit mode. 

Implementations of the invention may include one or more of the following. Each 
placeholder includes one or more annotations describing the content for the placeholder. 
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These annotations are used to generate content to replace the placeholder. The content as 
interpreted by the annotations are retrieved from the content sources. Each placeholder 
can be formatted. The formatting the content can be adjusted to match the format of the 
placeholder. The method can also interpret the layout; and replace the content in lieu of 
5 the placeholder when rendering the document The placeholder can be restored when the 

designer edits the page in an edit mode. Metadata for the placeholder can be stored as a 
comment field in the document. 

In another aspect, a method applies a document by: inserting one or more mark- 
up elements in the document; binding the mark-up elements to one or more content 

10 sources; retrieving data from the bound one or more content sources and replacing the 

mark-up elements with the retrieved data during run-time; and restoring the mark-up 
elements during an edit session. 

Implementation of this method can include updating a markup language document 
during run-time based on an original layout and content generated on-the-fly. Further, the 

1 5 content replaces the placeholder. 

In another aspect, a method generates a document having one or more mark-up 
elements, each elements being bound to a content source. This is done by specifying one 
or more parameters; retrieving data satisfying the one or more parameters from the bound 
content source; replacing the mark-up elements with the retrieved data; and displaying the 

20 document 

Advantages of the system may include one or more of the following. A designer 
can use a WYSIWYG editor to create a web site design in HTML. The system then uses 
the format, layout and style of the HTML to insert, format, layout and style the content 
Because the system uses HTML, any HTML tool can be used to refine or edit the design. 

25 The system supports a designer-friendly approach to incorporating the content 

technology of ASPs in a Web site. Powerful features for Web site designers, 
programmers, and intranet or e-cornmerce developers are supported, including the ability 
to work on or offline; add content sources to a page without writing a single line of script 
code; highlight placeholder text and graphics linked to content; customize numeric 

30 formatting and replication of table rows; link to pages; preview pages using placeholder 

or actual content; and generate all HTML and ASP code necessary for automatic content 
generation. 

The system makes it easy to integrate content into a Web site. A web designer 
may create a web page using a conventional markup language and bind one of many 

~4- 
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database type fields to a portion of the markup language. Furthermore, the designer may 
replace the binding at a later time to another independent database to the same markup 
language portion* The two databases themselves may not be compatible to each other. 

The Web designer can have complete pixel-level control over HTML in a visual 
design environment, while automatically generating industry-compliant ASP or other 
server code. The designers can see exactly how their designs look on different platforms 
and browsers in an Edit mode. Moreover, the system provides management tools to make 
it easier to create and maintain Web sites. Furthermore, as the content of the database 
fields that are bound to a portion of the markup language is changed, the generated web 
page is changed accordingly. 

The system provides a complete solution for HTML layout, design, and Web site 
management Designers have creative control and flexibility when designing Web sites. 
It lets graphic designers and publishers design and manage professional-quality Web sites 
containing the latest multimedia features, without requiring any HTML programming. At 
the same time, it provides HTML source-code and JavaScript tools to help Web designers 
and programmers integrate interactivity into their sites. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a flowchart illustrating a process for generating content using one or 
more mock placeholders. 

Fig. 2A is an exemplary user interface illustrating one or more mock placeholders 
and their content sources. 

Fig. 2B is an exemplary user interface illustrating one or more mock placeholders 
and binding details associated with the placeholders. 

Fig. 3 is a flowchart of a process for processing the mock placeholders. 

Fig. 4 is an exemplary user interface illustrating various exemplary mock 
placeholders and their content sources. 

Fig. 5 is a flowchart of a process for interpreting the content associated with the 
mock placeholders. 

Fig. 6 is an exemplary computer system for executing the process of Fig, 1. 
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DESCRIPTION OF THE PREFERRED EMBODIMENTS 

Referring now to Figure 1, a process 100 for editing and running pages with 
content is shown. In applying the process 100, a designer creates pages as usual, placing 
mock elements or placeholders on the page in place of actual content. The mock content 
lets the designer visually design the page exactly the way it should appear to the designer. 
After designing the page in this way, the designer binds or links the placeholders to fields 
in an online database, or a server such as an e-commerce server that provides data. The 
content of those fields replaces the mock content oh the page when it appears live or is 
previewed. 

Specifically, the designer layouts a page with mock content placeholders (step 
102). Next, the designer formats the mock content placeholders as necessary (step 104). 
The designer can format placeholders the same way he can format non-placeholders* 
This includes setting font and style attributes for text; height and width for images; 
borders, height, width, and cell spacing for tables; and others. Steps 102 and 104 can be 
done using any HTML authoring tool, including GoLive, available from Adobe Systems 
Incorporated of San Jose, California. 

The designer then associates one or more annotations with the placeholders (step 
106). In one implementation, the designer selects a table from a database and then binds 
individual fields from that table to placeholders on the page. These annotations tell the 
system what database tables the page needs to access. An image, for example, may have 
an annotation that tells the process 100 to replace the source of the image with the content 
of a particular database field. In another example, a piece of text may have an annotation 
that tells the process 100 to replace the text with the conten* of another database field. 
When the page is saved as a file, the annotations are turned into code that will get the 
appropriate data and make it available to the page during display. 

Annotations can be inserted manually or automatically. Pseudo-code for one 
annotation embodiment is as follows: 

1 . Find the tag that corresponds to the selected object. 

2. Find the attribute list for the tag 

3. Compute the annotations needed to describe the behavior of the selected 
object 

4. Add the annotations as attributes to the attribute list, replacing old 
attributes that have the same name with the new ones. 
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From step 1 06, the annotations are used to compile the placeholders into 
executable code to retrieve content (step 108). This is done when the page is saved as a 
file. 

Next, in step 1 10, the process 100 determines whether the user is in edit mode or 
view mode. If the user is in the view mode, the process 100 proceeds to step 112 where 
the page is displayed. In this step, each placeholder is analyzed, and based on the type 
and the annotations of the placeholder, appropriate code is generated that will put in the 
actual content Alternatively, the annotations can be interpreted to fill the page with 
content. At run-time or edit time, the information in the annotations is processed to 
replace the placeholders with the actual content (interpretation). Finally, the page can be 
rendered with the content 

From step 1 10, if the user is in the edit mode, when the page is read, the code is 
decompiled back to the original placeholders and annotations so that the designer can edit 
them and change the layout (step 1 14). From step 1 12 or 1 14, the process 100 exits. 

Figure 2A shows an exemplary layout using an HTML editor such as Adobe's 
GoLive. GoLive provides a context-sensitive palette called the Inspector can be used to 
let the designer quickly customize objects without using commands in the menu bar. The 
context-sensitive Inspector can be used to set the attributes of text or objects in the page 
or site window. Inspectors are the source of point-and-shoot linking; they also let the 
designer reference image files or other resources, resize elements with pixel-level 
precision, align objects with respect to adjacent text, control object spacing between 
objects, and make many tag-specific settings. 

The layout 120 of Figure 2A has a background table, which in turn includes table 
cells 124, 126, and 140* The table cell 124 contains various elements such as of an 
"Adobe Magazine" icon and a '"Contents" table. The table cell 126 contains text fields 
"Ducky takes 1 st prize" and "The ImageReady rubber ducky has surprised everyone, 
including its creators, by taking first prize in a local duck beauty pageant" The table cell 
126 also includes an image 130 to make the Web page more visually appealing. Finally, 
the table cell 140 includes a plurality of hotlinks to various featured articles. 

Fig. 2A also shows a plurality of panes, including a binding details pane and a 
content sources pane 1 50. Once the designer adds a content source, the pane 1 50 allows 
the user to bind placeholders to specific fields in the online database that serves as the. 
content source. The designer can select the placeholder and then select the field desired 
in the content sources pane 150 to bind the two. The designer can also enter or edit the 
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paths in the URL to a "Config Folder" from this pane. These paths let the system find and 
use various files it needs for content, including the designer's databases* 

When the designer selects on a particular element, one or more corresponding 
fields becomes highlighted and checked in the content sources pane 150 of the contents 
palette. When a table is bound to a content source and the contents of a row to a field 
within that content source, the page when previewed or viewed online places the contents 
of that field for each database record into each subsequent row of the table. The text in 
previous rows without bindings remains as headings. For example, if there are eight table 
rows, the contents of that database field for eight records will appear one after another, 
one record for each row. 

hi Fig. 2 A, if the rubber duck image 130 is selected, the ImageURL field becomes 
highlighted and checked in the content sources pane of the Dynamic Content palette. This 
tells the designer that the currently selected placeholder is linked or bound to a field 
called ImageURL in the online database. The contents of that database field will replace 
the placeholder when the user previews the page or views it online. In this example, the 
database will insert a URL to a graphic element 

Operations associated with an exemplary placeholder are discussed next In 
Figure 2A, the image placeholder 130 can be added by putting an image placeholder on 
the page and then linking the placeholder to an image file. The image placeholder can 
then appropriately positioned on the page. 

Similarly, to insert a text element with a title and a body, two text placeholders 
132 and 134 on the page are created. The box next to a Title field listed in the content 
sources pane 150 is selected to bind the placeholder 132 to the Title field of the database. 
Next, the body placeholder 134 is selected, and the box next to the Introduction field in 
the Content Sources pane 150 is selected to bind the placeholder 134 to another field in 
the database. Finally, the Show Bindings button in the Dynamic Content palette is 
selected. At this point, the page can be previewed to see the content in action. 

Specific portions of the HTML code for the sample page shown in Fig. 2 A is 
shown below: 

<!- #INCLUDE FILE== tt .7config/include/utils.asp M -> 

<!- #INCLUDE nLE= ,, ../config/include/ado.asp M --> 

<!DOCTYPE html PUBLIC "-//W3C/DTD HTML 4.0 TransitionaI/EN w > 

<html> 

<head> 

<meta http-equiv="content-type" conten^text/htmUcharset^so-SSSP-l H > 
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<meta name^generator" content^" Adobe GoLive 4"> 
<title>Adobe Magazine</title> 
<WDynamic Link 

set Feature^InfonnationRecordSet = CreateObject( M Ar>ODB.Reco^dSet ,, ) 
FeatureJfofonnationRecordSetOpen "select * from features order by Priority", 

Ck)rmectString("Magazine M ) 

set Featurejnformation = WiapRecoidSet(FeatureJtofonnationRecordSet) 

%> 
</head> 

<body bgcolor^white'^ 
<table boider= M 0" ceilpadding="0 H cellspacing-" 10"> 
<trheight= H 500"> 
<td valign="top" height^SOO^ 
<h2><img src= M images/logo.gif width="226" height^" 1 5 5 M x/h2> 
<h2> 

<table border= n 0 H cellpadding= n 0" cellspacing-"O n width-" 145"> 
<tr> 

<td width-"33 <, X/td> 
<td> 

<3h2>Contents<yh2> 

<pxa hre^ w frontpage.asp">Home<ya><br> 
Features<br> 
Q & A</td> 
</tr> 
</tabte> 
<fh2> 
<ftd> 

<td vaIigrF= H top w align="right" height= w 500 tt > 
<h2><%-FeatureJbifonnation.Valu 
<p><%=Feature_Infonnatio 

<pximg src^<^FeatureJtofonnation. ValuenmageURL")^' width="280" 
height="170"x/p> 
<pxa 

href^ n fullarticle.asp?RECOI^^ 
">fti!l story</a></td> 

<td widths" 1 n valign-"top" bgcoIor="black" heightr= n 500"ximg 
src= M images/spacer.gir width^'l" height= H rx/td> 

<td valign= H top" height= w 500"> 
<h2>Featurcs</h2> 

<P> 
<table> 

<% FeatureJtafonnation.MoveFirst %> 
<% FeatureJfafonnation*Move 2-1 %> 
<% while not Feature_Infonnation.EOF %> 
<tr> 
<tdxa 

href^"fiUlarticle.asp?RECOR 
"><%=FeatureJnfo^ 
<hr> 
</td> 
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</tr> 

<% Featuxe_Information.MoveNext %> 

<% wend %> 
</tabIe> 
</p> 

<p>more stories...</td> 
</tr> 
</table> 
<body> 

</html> 

<%if0then%> 
<!~Mock Content 

FeanireJWbrmation:<TABLE> {<tr> <^^<ahref="fuIlarticle.asp w >Kidnappers 
foiled in plot to nab ducky <hr> </ax/td> </tr> <tr> <tdXa 
href= w fulIarticle.asp H >Geese making angry noises about rigged judging <hr> 
</aX/td> </tr> <tr> <td><a hre5== n fullarticle.asp ,, >Hordes of six year olds pack airport 
awaiting ducky's triumphant return <hr> </aX/td> </tr> <tr> <tdxa 
hre^ H fullarticle.asp H >Eating duck a la orange without feeling guilty <hr> </ax/td> 
<itx> <tr> <td><ahrei^ ,, fuHarticle*asp ,, >Is synthetic rabber the latest trend?</a> <hr> 
<ftd> </tr> } 

Feature_Information:Title {Ducky takes 1st prize} 

Featurc Informationrlntroduction {The ImageReady rubber ducky has surprised 
everyone, including its creators, by taking first prize in a local duck beauty pageant} 
Feature Jtoformation:Title {Local designer declares yellow passe} 
Featurc_Information:ImageURL {images/ducky(big)jpg} 

~> 

<%endif%> 



As shown above, the design for the page whose contents are changed on the fly to 
suit certain user qualifier or parameters can be created using existing HTML elements. 
An element can be tagged (using an attribute, among others) to be associated with some 
form of content At run-time, the representative content is examined to format, style, and 
layout the content When editing, the <— Mock Content . . .> tag enables the system to 
replace the content with the mock placeholders so that the page can be easily edited. 

Fig. 2B shows an exemplary user interface 180 illustrating one or more mock 
placeholders and binding details associated with the placeholders. The binding details are 
aggregated in a binding details pane 1 80. The "Bind To" area of the Binding Details pane 
is available whenever any placeholder is selected. The "Filter** area appears for text 
placeholders only. The "Link To" area appears only when an HTML link is selected on 
the Web page. The "Binding Details" tab opens a pane in the palette where a designer 
can fine-tune bindings by selecting additional options that appear there. These options 
vary depending on the type of field involved in the binding, but can include: applying text 
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formatting filters to format content such as currency and dates; linking to other pages; and 
creating "Previous" or "Nexi" buttons to navigate between records. 

Referring to Figure 3, a process 200 is shown for using placeholders for 
generating either viewable content or layout. First, the process 200 generates code to get 
contents from a database (step 202). In one embodiment, code to get information from a 
database is as follows: 
<% 

set Story_InformationRS= CreateObject( w ADODB.RecordSet") 
StoryJtaformaiionRS.Open "select * from features**, 
ConnectString("Magazine'') 

set Story_Information== Wi^RecordSet(Story_InfonnatioriRS^ 
StoryJtaformation.Move Request.QueiyString("RECORD_INDEX") - 1 

%> 

Next, this code is embedded as HTML or XML attributes on the placeholder (step 
204) or simply stored as an HTML element or an XML element. XML is a simplified 
dialect of SGML (Standard Generalized Markup Language) for the structured 
presentation of information on the World Wide Web. XML is a subset of SGML for 
defining custom markup languages. XML documents use Document Type Definitions 
(DTDs) that define the custom tags available for use in the document More information 
on XML is provided at www.w3.org/XML/ or at www.xml.com/ 

Finally, the process 200 also saves mock content placeholders so that, it should be 
used as decide to edit the page in a edit mode, the mock content placeholders can be 
restored for the designer to edit 

Although the process 200 shows content generation from the point of a designer, a 
user can influence the generation of content as well. In anc&er embodiment, the user can 
control the type of content that the web page is to display. The user can specify his or her 
desired content using a qualifier along with the entry of a web site address. For example, 
the user can search for all stories by a particular author bv entering "www.publisher.com 
author — Tran." The returned web page would be customized to the user's qualifier and 
would return only contents that had been authored by the desired user qualifier. The code 
generated for a link of this example is shown below: 

<%*Dynamic Link set Story InformationRecordSet - 
CreateObject("ADODB.RecordSer) 

StoryJtaforrnationRecordSetppen "select * from Features where Author = 
& RequestQiMyStringrAuthor") & order by Priority", 
ConnectString("Magazine^ 

set Storylnformation = WrapRecordSet(Story_InformationRecordSet) 



WO 01/42972 



PCT/USOO/42700 



, %> 

To illustrate with an example, a placeholder element with annotations typically is 
expressed in HTML as: 

<IMG src^'ducky.jpg" dynamic_src="Stoiy Information:IrrmgeURL'> 

The IMG tag additionally has an attribute called dynamic src, which represents an 
annotation, which allows the system of Fig. 1 to turn the mock placeholder into content 
during a "live** rendering of the page. In addition, in edit mode, an editor such as Adobe 
GoLive can still show the IMG tag as a regular image of a duck. 

In one embodiment, code to generate an image is: 
<% 

[code to get content from the database] 

%> 

<IMG sic-"<%=Story_Infonnati 

<!— Mock Content Story_Ihformation:ImageURL {ducky.jpg} ~> 

The last section lets the system reverse the compilation process for generating 
pages and turn the code back into an HTML page that the designer can edit the page as 
necessary. 

The invention operates with various other placeholder types. For instance, the 
page layout of Figure 4 has a text placeholder 250, an image placeholder 252, a table 
placeholder 254, a text input box placeholder 256, a pull-down menu placeholder 258, a 
radio box placeholder 260, a checkbox placeholder 262 and a hotlink placeholder 264. A 
content source tab 270 is in turn associated with each of the placeholders 250-264. 

Exemplary code for the text placeholder 250 is as follows: 

<%=Product_Info.Value( <t Name ,r >%> 

This code inserts the text of the "Name" field from the current record of the 
"Product_Info" table. The current record is set by the code that retrieves the database 
information. The formatting depends on the tags surrounding the code. If the code is 
within an <H1> tag, for example, it is formatted as a heading. 

Exemplary code for the image placeholder 252 is as follows: 

<fmgheight=="32" width="32" src« , <%^Infomation.Value("ImageUR^ 
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This code replaces the src attribute of the image with the text of the ImageURL 
field. Replacing the src attribute causes the user's browser to retrieve the image 
referenced by the ImageURL. 

Exemplary code for the table placeholder 254 is as follows: 

<table border="4" cellpadding-"0" cellspacing-'^" width="119"> 
<% ProductJtafo-MoveFirst %> 
<% while not Product JtafaEOF %> 
<tr> 

<^><%HEWuctJiifc^ 
</tr> 

<% PnKluctJmfo.MoveNext %> 

<% wend %> 

</table> 



This code constructs a table that shows all the records in the Product_Info table, 
with one record per row. Each row will display the Name of one product The table will 
have the formatting indicated by the attributes in the <TABLE> tag. 

Exemplary code for the text input box placeholder 256 is as follows: 

<input type= M text" value='<%^ProductJ^^ 
narae=='Title" size="24"> 

This code creates a text input box for updating the Name field of the current 

record. The information will be uploaded to the database as part of a form submission. 

Exemplary code for the pull-down menu placeholder 258 is as follows: 

<select name-Title" size="l"> 

<% ShippingJMethods.MoveFirst %> 

<% while not Shipping_Methods.EOF %> 

<option value=*<^SWppingLMethods.Value{"Meu^ 

name= w ShippingMethod" 

<%^le<^ed(ProductJnfo.Value("ShippingMethod") 
SMppmgLMetiK>ds.Vato^^^ 
MethodName")%> 

<% ShippingLMethods.MoveNext %> 

<% wend %> 

</select> 

This code constructs a pull down menu to update the ShippingMethod field of the 
current record. The entries in the menu are created from the records in the 
Shippin&JMethods table, each of which has a MethodName. The code is further designed 
to show the shipping method assigned to the current record. 

Exemplary code for the radio box placeholder 260 is as follows: 
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<input type="radio" value~*<y^Infonnati^^ 
name="Title" <%^hecked(Infon^on.Value( < Title M ) 
Lrfonnation.ValueC < Subtitle"))%>> <%-Infoitifmtion.Value(*TitIe w )%> 



<table border="0" ceUpadding=*2" cellspacing="2"> 
<% Status JJstMoveFirst %> 
<% while not StatusJListEOF %> 
<tr> 

<tdxinput type-'radio" valuer* <^Status_List.Value( < TrojectStatus ,, )%>* 
name^'TrojectState" 

StatusJList.Value('Ttojec«^ 

</td> 

</tr> 

<% Siatus_ListMoveNext %> 

<% wend %> 

</table> 

This code fills the rows of a table with radio buttons to set the ProjectStatus field 
of the current Record. The code is similar to the pulldown menu code: entries are 
constructed from one table in the database (StatusJList), and the current value is taken 
from another table (the current record selected in the Project Information table). This 
code would typically be part of a form that the user could use to update the status of a 
project. 

Exemplary code for the checkbox placeholder 262 is as follows: 

<input type="checkbox" value^T' name="OnSale" 
<%^hecked(cint(Produ^ o 0)%>xinput 

type-chidden" 

name-"~OnSale" value="0"> 

This code creates a checkbox form control to update the value of the OnSale field 
of the current product. The extra code for the hidden input works around a limitation of 
HTML when updating Boolean fields in a database. 

Exemplary code for the hotlink placeholder 264 is as follows: 

<a href=^product_details.asp? 
RECORD JCEY-&jueryStm^ 
<%^Product_Info.Value("Name ,, )%></a> 



This code creates a hotlink to another page, product_details.asp that will show 
more information about the current product. The Product Jnfo.KeyO code passes the key 
for the current product to the details page so that it knows which record to show. 
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The code in these examples uses ASP (Microsoft's Active Server Page 
technology), but it could equally well use any other server side scripting format, including 
Java Server Pages (JSP)., PHP, and Perl. The internal annotation format also supports 
conversion among different formats by converting one format into the internal annotation 
format and then outputting the data in a different format. 

The design is created using existing HTML elements. An element can be tagged 
(using an attribute, among others) to be associated with some form of content At run- 
time, the representative content is examined to format, style, and layout the content. 

The annotations are stored as XML or HTML attributes. This has the advantage 
that the file stays an XML or an HTML file, so that the designer can continue to edit it 
using existing XML and HTML tools. In contrast, other output formats do not use this 
model. ASP code, for example, is unstructured and cannot typically be read into an 
HTML editor. 

Using the attribute format makes it easy to apply an interpreter that processes the 
content at runtime. An interpreter is a computer program that translates and executes 
instructions written in an interpreted programming language, such as programs written in 
Perl, Basic, or Java. The translation process involves the conversion of each source 
language statement of a given computer program into machine language suitable for 
execution. A user wishing to execute an application program written in the programming 
language will invoke an interpreter in order to execute the application program. The 
interpreter can simply parse the page as an XML or HTML document, and then using the 
standard DOM interface for accessing such a document, it can find the content 
annotations, fetch the required content, and substitute for the placeholders. 

Referring now to Fig. 5, a process 300 for interpreting the content is shown. First, 
the process 300 retrieves the next placeholder from the document (step 302). The process 
300 then reads the annotations describing the content that should replace that placeholder 
(step 304). The required content is retrieved (step 306). The process 300 then formats 
the content to match the formatting of the placeholder (step 308) and replaces the 
placeholder with the content (step 310). Next, the process 300 checks whether all 
placeholders have been processed (step 312). If not, the process 300 loops back to step 
402 to continue processing the placeholders. Alternatively, the process 300 proceeds 
from step 312 to display the final document showing all the content (step 314). 

Pseudo-code to display a document by interpreting the content annotations is 
shown below: 



- 15- 



WO 01/42972 



PCT/USOO/42700 



1 . Read the next placeholder from the document. 

2. Read the annotations that describe the content that should replace that 
placeholder. 

3. Retrieve the required content 

4. Format the content to match the formatting of the placeholder. 

5. Replace the placeholder with the content 

6. Continue with step 1 until all placeholders have been processed. 

7. Display the final document showing all the content 



The invention may be implemented in digital hardware or computer software, or a 
combination of both. Preferably, the invention is implemented in a computer program 
executing in a computer system. Such a computer system may include a processor, a data 
storage system, at least one input device, and an output device. Figure 6 illustrates one 
such computer system 600, including a processor (CPU) 610, a RAM 620, a ROM 622 
and an I/O controller 630 coupled by a CPU bus 698. The I/O controller 630 is also 
coupled by an I/O bus 650 to input devices such as a keyboard 660, a mouse 670, and 
output devices.such as a monitor 680. Additionally, one or more data storage devices 692 
are connected to the I/O bus via an I/O interface 690. 

Further, variations to the basic computer system of Figure 5 are within the scope 
of the present invention. For example, instead of using a mouse as user input devices, a 
pressure-sensitive pen, digitizer or tablet may be used. 

The above-described software can be implemented in a high level procedural or 
object-oriented programming language to operate on a dedicated or embedded system. 
However, the programs can be implemented in assembly or machine language, if desired. 
In any case, the language may be a compiled or interpreted language. 

Each such computer program can be stored on a storage medium or device (e.g. , 
CD-ROM, hard disk or magnetic diskette) that is readable by a general or special purpose 
programmable computer for configuring and operating the computer when the storage 
medium or device is read by the computer to perform the procedures described. The 
system also may be implemented as a computer-readable storage medium, configured 
with a computer program, where the storage medium so configured causes a computer to 
operate in a specific and predefined manner. 
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WHAT IS CLAIMED IS: 

1. A method for generating a document, comprising: 
inserting one or more placeholders in the document; 
binding each placeholder to a content source; and 

using the placeholders to generate content for the document based on their content 
source and presenting the generated content of the document if in a presentation mode or 
restoring the placeholders if in an edit mode. 

2. The method of claim 1 , wherein using the placeholders to generate content 
comprises: 

compiling the placeholders into executable code; and 
executing the code to generate the content for the document. 

3. The method of claim 1, wherein the step of using the placeholders to generate 
content comprises interpreting the placeholders. 

4. The method of any of claims 1,2 or 3, further comprising formatting the 
placeholders. 

5- The method of any of claims 1 > 2 or 3, further comprising annotating the 
placeholders. 

6. The method of claim 2, further comprising annotating the placeholders, wherein 
executable code is generated from the annotations to retrieve the content for the 
document 

7. The method of claim 3, further comprising annotating the placeholders, wherein 
each annotation of a placeholder describes the content for the placeholder, further 
comprising reading the annotation that describes the content to replace the placeholder. 

8. The method of claim 7, further comprising retrieving the content as interpreted by 
die annotations. 

9. The method of claim 4, further comprising formatting the content to match the 
format of the respective placeholder. 

10. The method of any of claims 1 , 2 or 3, further comprising replacing the 
placeholders with their respective content when generating the document. 

1 1 . The method of claim 1 or 2, further comprising generating a document page based 
on the content 

12. The method of claim 2, wherein compiling the placeholders into executable code 
further comprises generating code to obtain content from a database. 
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1 3. The method of claim 2, further comprising embedding the executable code as 
attributes in the placeholders. 

14. The method of claim 1 or 2, wherein the placeholders are mark-up elements. 

15. The method of claim 14, wherein the mark-up elements are HTML or XML 
elements. 

16. The method of claim 1 or 2 further comprising specifying a content insertion 
based on the placeholders, each placeholder having a representative content. 

1 7. The method of claim 1 6, further comprising using the formatting, styling, or 
layout of the representative content of the placeholder to format, style, or layout the 
content of the document 

18. The method of any of claims 1, 2, or 3, further comprising storing metadata for the 
placeholders as a comment field in the document. 

19. A method for processing a document; comprising: 
inserting one or more mark-up elements in the document; 
binding the mark-up elements to one or more content sources; 
retrieving data from the bound one or more content sources; 

replacing the mark-up elements with the retrieved data during run-time; and 
restoring the mark-up elements during an edit session. 

20. The method of claim 19, further comprising updating a markup language 
document during run-time based on an original layout and content generated on-the-fly. 

21 . The method of claim 20, wherein the content replaces the placeholders. 

22. A method for generating a document having one or more mark-up elements, each 
element being bound to a content source, the method comprising: 

specifying one or more parameters; 

retrieving data satisfying the one or more parameters from the bound content 

source; 

replacing the mark-up elements with the retrieved data; and 
displaying die document. 

23. A computer readable medium for generating a document, comprising instructions 
to: 

insert one or more placeholders in the document; 
bind each placeholder to a content source; 
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use the placeholders to generate content for the document based on its content 
source and present the generated content of the document if in a presentation mode or 
restoring the placeholders if in an edit mode. 

24. A computer readable medium for processing a document, comprising instructions 
to: 

insert one or more mark-up elements in the document; 

bind the mark-up elements to one or more content sources; 

retrieve data from the bound one or more content sources; 

replace the mark-up elements with the retrieved data during run-time; and 

restore the mark-up elements during an edit session. 

25. A computer readable medium for generating a document having one or more 
mark-up elements, each elements being bound to a content source, comprising 
instructions to: 

specify one or more parameters; 

retrieve data satisfying the one or more parameters from the bound content source; 
replace the mark-up elements with the retrieved data; and 
display the document. 

26. A system for generating a document, comprising: 

means for inserting one or more placeholders in the document; 

means for binding each placeholder to a content source; and 

means for using the placeholders to generate content for the document based on its 
content source and for presenting the generated content of the document if in a 
presentation mode or restoring the placeholders if in an edit mode* 
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